// Copyright (c) 2025, 大连理工大学 (Dalian University of Technology)
//
// Licensed under the Mulan PSL v2.
// You can use this file according to the terms and conditions of the Mulan PSL v2.
// You may obtain a copy of the License at
//
//     http://license.coscl.org.cn/MulanPSL2
//
// THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
// EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. SEE THE MULAN PSL v2
// FOR MORE DETAILS.

/*
 * @Author: qiulin 1746365080@qq.com
 * @Date: 2024-11-05 17:41:14
 * @LastEditors: qiulin ql1746365080@gmail.com
 * @LastEditTime: 2024-12-12 15:11:51
 * @FilePath: /SGSim/Import/BDFImport/UnitTest/Load/QBDY3ParserTest.cpp
 */

#include "Import/BDFImport/BulkData/Load/QBDY3Parser.h"

#include "gtest/gtest.h"

#include "DataStructure/Common/Constant.h"
#include "DataStructure/Input/Load/QBDY3Data.h"

#include "DBManager/DBServiceFactory.h"
#include "DBManager/IService/Input/Load/IQBDY3Service.h"

#include "Import/BDFImport/BDFParserBase.h"
using namespace SG::DBManager;
using namespace SG::Import;

using SG::DataStructure::Common::TOLERANCE;
using namespace SG::DataStructure::FEM;
extern std::shared_ptr<DBServiceFactory> DB_SERVICEFACTORY;
extern std::vector<std::string>          dividedEntryInfo;

class QBDY3ParserTest : public ::testing::Test
{
  public:
    static void SetUpTestSuite ()
    {
        DB_SERVICEFACTORY->ClearDatabase ();
    }
};

TEST_F (QBDY3ParserTest, ParseEntry1)
{
    std::vector<std::string> Entry = { "QBDY3    2      5000.            100001" };
    BDF::divideBulkEntry (Entry, dividedEntryInfo);
    SG::Import::BDF::BULKDATA::ParseQBDY3 (DB_SERVICEFACTORY, dividedEntryInfo);
    std::vector<SG::DataStructure::FEM::QBDY3Data> forces;

    SG::DataStructure::FEM::QBDY3Data data;

    DB_SERVICEFACTORY->get<IQBDY3Service> ()->FindBySId (2, forces);

    data = forces[0];

    ASSERT_TRUE (data.m_EID == 100001);
    ASSERT_TRUE (data.m_CNTRLND == 0);
    ASSERT_NEAR (data.m_Q0, 5000.0, TOLERANCE);
}
